$(function () {
  let layer = layui.layer;
  let form = layui.form;
  // 渲染文章分类
  initArtCateList();
  function initArtCateList() {
    axios({
      method: "GET",
      url: "/my/article/cates",
    }).then(function (res) {
      if (res.data.status !== 0) {
        return layer.msg(res.data.message);
      }
      let arr = ['<option value="">请选择文章类别</option>'];
      res.data.data.forEach((ele) => {
        arr.push(`
    <option value="${ele.Id}">${ele.name}</option>
             `);
      });
      // 赋值
      let str = arr.join("");
      $("[name=cate_id]").empty().html(str);
      // form 表单同步渲染
      form.render();
    });
  }

  // 初始化富文本编辑器
  initEditor();

  // 1. 初始化图片裁剪器
  var $image = $("#image");

  // 2. 裁剪选项
  var options = {
    aspectRatio: 400 / 280,
    preview: ".img-preview",
  };

  // 3. 初始化裁剪区域
  $image.cropper(options);

  // 需求4 确定状态
  let state;
  $("#btnSave1").on("click", function () {
    state = "已发布";
  });
  $("#btnSave2").on("click", function () {
    state = "草稿";
  });

  // 需求5 选择封面
  $("#chooseImage").on("click", function () {
    $("#file").click();
  });

  $("#file").on("change", function (e) {
    // 拿到用户选择的文件
    var file = e.target.files[0];
    // 根据选择的文件，创建一个对应的 URL 地址：
    var newImgURL = URL.createObjectURL(file);
    // 先`销毁`旧的裁剪区域，再`重新设置图片路径`，之后再`创建新的裁剪区域`
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", newImgURL) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });

  // 表单提交
  $("#formPub").on("submit", function (e) {
    e.preventDefault();
    let fd = new FormData(this);
    // 添加状态
    fd.append("state", state);
    $image
      .cropper("getCroppedCanvas", {
        // 创建一个 Canvas 画布
        width: 400,
        height: 280,
      })
      .toBlob(function (blob) {
        // 将 Canvas 画布上的内容，转化为文件对象
        // 得到文件对象后，进行后续的操作
        fd.append("cover_img", blob);

        axios({
          method: "POST",
          url: "/my/article/add",
          data: fd,
        }).then((res) => {
          if (res.data.status !== 0) {
            return layer.msg(res.data.message);
          }
          layer.msg("恭喜您，添加文章成功！");
          setTimeout(function () {
            window.parent.document.querySelector("#art_list").click();
          }, 1500);
        }); 
      });
    // console.log(...fd);
  });
});
